class code3 {
    //存在重复元素 II:滑动窗口，定窗口大小为k，看窗口中是否有nums[i]
    public boolean containsNearbyDuplicate(int[] nums, int k) {
        Set<Integer> set = new HashSet<>();
        int i=0;
        while(i<nums.length) {
            //更新结果
            if(set.contains(nums[i])) {
                return true;
            }
            //进窗口
            set.add(nums[i++]);
            //判断
            if(set.size() > k) {
                //出窗口
                set.remove(nums[i-k-1]);
            }
        }
        return false;
    }
}